import { Separator } from "@/components/ui/separator" import { type SearchParams } from "@/types/table" import { getValidFilters } from "@/lib/data-table" import { getMatchedVendors } from "@/lib/rfqs/service" import { searchParamsMatchedVCache } from "@/lib/rfqs/validations" import { MatchedVendorsTable } from "@/lib/rfqs/vendor-table/vendors-table" import { RfqType } from "@/lib/rfqs/validations" interface IndexPageProps { // Next.js 13 App Router에서 기본으로 주어지는 객체들 params: { lng: string id: string } searchParams: Promise rfqType: RfqType } export default async function RfqPage(props: IndexPageProps) { const resolvedParams = await props.params const lng = resolvedParams.lng const id = resolvedParams.id const rfqType = props.rfqType ?? RfqType.BUDGETARY // rfqType이 없으면 BUDGETARY로 설정 const idAsNumber = Number(id) // 2) SearchParams 파싱 (Zod) const searchParams = await props.searchParams const search = searchParamsMatchedVCache.parse(searchParams) const validFilters = getValidFilters(search.filters) const promises = Promise.all([ getMatchedVendors({ ...search, filters: validFilters, }, idAsNumber) ]) // 4) 렌더링 return (

Vendors

등록된 협력업체 중에서 이 RFQ 아이템에 매칭되는 업체를 보여줍니다.
"발행하기" 버튼을 통해 RFQ를 전송하면 첨부파일과 함께 RFQ 내용이 메일로 전달되고 eVCP에도 협력업체가 입력할 수 있게 자동 생성됩니다.

) }